package drg_group.suzhou_2023.MDC;

import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;

import drg_group.suzhou_2023.Base;
import drg_group.suzhou_2023.MedicalRecord;
import drg_group.suzhou_2023.ADRG.*;

public class MDCX{
    public static String group(MedicalRecord record){
        String[] mdc_zd={"T92.300x008","M23.209","Z65.200","T93.300x002","R84.902","Z20.300","T92.503","Q93.200","T92.500x004","Z73.500","Z51.400x002","T93.600","Z59.500","R58.x00x007","B90.803","R89.000","Z60.800","Z71.100","Z75.800x001","Z47.800x014","Z22.600","Z31.800","Z57.507","Z70.100","T98.200x032","Z39.200x001","Z26.000","Z39.100x001","Q95.800","Z47.800x036","R49.801","Z43.500","B90.202","Z73.800","Z63.000","Z62.300x001","Z29.200x001","T92.300x002","Z03.600x001","Z52.900","T93.201","R89.100","T90.208","Z20.001","Z30.800x003","Z43.302","Z11.802","T92.100x010","Z27.400x001","Z43.601","R58.x00x004","Q92.800","R63.200x002","B94.800x001","R63.400","T93.103","T93.400x003","Z20.100","Z50.100x001","Z09.804","Z25.100","T90.203","Z30.400x001","Z54.100","R74.804","Z63.600","R68.800x003","R77.803","Z65.300x001","R79.804","Z70.000","R53.x00x004","R47.100x001","Z24.601","M23.203","T93.300x009","M24.100x091","Z62.200x001","Q85.914","R41.001","R18.x00x003","R47.801","R70.100","Z03.800x731","Z51.901","Q91.400","T93.300x005","T95.000x006","Z55.200","T92.500x009","Z04.900","R46.700","T91.206","B90.800x006","R52.000","Z09.000x001","Z09.803","R74.000x001","Z64.200","Z57.700","R68.000","T93.400x005","Z43.400x002","Z13.800x011","Q93.600","T92.500x015","Q95.500","R13.x00","Z30.504","Z65.000","T91.900x002","Q92.200","Z60.900","Z13.500","T70.400","Q95.400","R96.100x001","Z00.800","Q91.500","T90.901","Z30.800x001","T93.200x008","Z22.700","Z51.401","Z03.803","T91.800x005","T94.001","R76.200x002","T95.000x009","T91.802","Z40.800","Z41.800x002","Z13.400x001","Z63.700x093","T84.900","T95.801","Z65.500x001","T92.400x006","Z71.600","T80.801","T95.802","Z00.100","Z54.000","Z09.001","Z57.504","Z12.300","R76.200","T91.000x003","Z22.300","R53.x00x006","Z71.400","Q99.900","R52.900","T92.104","T91.900","T95.800x004","T91.201","Z47.800x012","R74.800x007","Z30.500x011","Z54.800x008","R77.800x002","T93.206","T92.100x004","R53.x00x001","R58.x00x002","T90.102","T92.300x007","Z30.503","T95.100x001","R23.000","Z13.900","B91.x00","T95.000x012","T92.500x006","Z30.101","T92.600","T78.900","T93.204","Z43.400x004","M23.204","Z62.900","Z28.000","T84.700x001","R17.001","R25.200x006","Z02.700","Z47.800x033","Z48.000x001","M24.808","R23.101","R23.200x002","T73.100","Z30.000x003","B90.100","Z55.800","Z43.300","Z70.900","R47.004","R47.003","Q97.300","R63.100x002","T91.803","Z13.800x021","Z01.600","Q98.600","R84.900x004","R93.301","T90.205","T91.200","Z11.803","Z30.201","T92.500x018","Z09.801","Q96.300","T90.400x001","Z22.302","R10.201","M24.807","Z65.500x003","Z59.000x001","T92.105","Z13.300x003","Z40.000x001","Z55.000","R19.000x016","R54.x00","Z45.802","Q95.000","R77.901","Z25.800x001","Z64.100x001","R89.500","Z10.800","T92.500x008","Z43.400x005","Q96.100","R54.x00x002","T95.300x001","Z54.000x009","Z29.100","Z65.800","Z57.201","R79.000x003","T92.500x017","T93.400x002","B90.000","T93.200x001","T92.400x007","T92.900","T91.002","R77.800x004","Z02.200","Z57.503","Q92.300","R52.100","Z13.000x001","Z56.400","T93.400","Z01.700","Z71.800","Z50.500","M23.501","Q96.400","Q89.900","T95.200x003","R19.000x003","Z57.508","T95.300x003","Z24.200","Z45.900","Z54.800x006","R47.802","Z75.500","Z43.101","T95.000x002","Q91.200","R25.200x004","Z54.900x001","R63.601","T93.200x011","Q97.100","T93.800x001","Z48.900x001","Z54.000x018","Z04.100","Z29.101","Z59.700","R79.000x006","R60.900","Z13.200","R47.000x006","Z46.501","Z58.400","Z64.400x001","Z54.000x022","Z47.800x028","Z28.100","T86.900","Z43.403","R17.000","T91.900x003","Z58.800","T92.500x001","Z22.102","R47.101","Z32.100","Z54.800x010","Z22.301","T93.200x014","Z47.800x005","Z76.201","R93.800x002","Q95.300","Q90.200","T92.300x005","T92.500x002","T90.900","Q87.800x907","Z01.300","Z09.700","Z46.502","Z54.800x004","Z20.702","R99.x00x002","Z57.100","R77.800x001","R26.100x001","Z01.101","Z41.300","Z47.800x031","R68.800x002","Z02.500","Z76.500","T95.200x005","Z00.300x001","Z23.200","T73.900","Z39.100x002","Q93.700","R19.000x012","T91.800x010","T91.800x009","B90.200","I69.801","Q98.300","Z24.600","T91.800x001","Z28.201","T90.000","Z12.100","R89.400","Z45.202","Z47.900","Z54.200x001","Z55.400","R58.x00x006","Z30.102","Z46.503","Q87.800x905","Z01.600x001","Z61.200x001","Z13.800x061","Z72.500","Z12.800","T92.505","T92.103","Q99.802","R79.000x002","R63.300x002","Z56.100","Z73.600","R41.800x002","R25.200x009","B90.800x004","T92.300x016","B90.801","Z63.700x011","Z13.500x001","B90.800x005","Z47.800x008","T90.200x008","Z50.600","Z63.500x001","T92.500x016","Z75.000","Z75.200","T93.801","R70.000","Z03.102","Q93.300","Q98.800","R77.200","Z20.701","T80.202","Z70.300","Q93.100","Z11.902","Z60.100x001","R18.x00","Z04.400","Z62.000x001","Z63.500x002","Z65.400x002","T95.800x002","R54.x00x003","Z24.300","M24.803","T92.305","Q99.100x003","Z45.803","Z55.100","T92.300x011","Z27.900","Z54.400","Z22.900x001","Z43.802","Z62.800","T85.800","N81.800x006","T73.300","Z47.800x030","T90.500x003","T95.800x008","Z52.300x002","Z72.400","T95.000x010","T92.106","Z13.501","Z02.000","R76.800x001","I69.400","T91.204","T95.103","Z47.800x032","Z56.700","Z58.000","Z59.200","Z70.800","R41.200","T91.205","Z23.300","Z63.300x001","Z63.200x001","Z43.102","Z04.800","Z13.800x051","R25.200x008","B94.201","Z54.000x012","Z63.400x003","Z31.900","B90.804","Q91.700","B92.x00","R68.100x002","Z47.800x021","R60.001","R59.901","T90.100","T95.101","M24.102","T92.506","Z63.100x001","T96.x00x001","R71.x00","Q99.101","Z65.300x004","T85.801","Q89.700","R74.802","Z47.800x007","T93.600x002","Z30.203","Z63.400x002","Z11.000","Z73.100x001","Z20.900","Z22.100","Z50.400x001","Q96.200","Z03.101","R70.101","T97.x01","Q92.400","Z65.300x002","T92.306","Z54.800x002","Z13.300","Z54.800x009","T95.200x001","Z29.201","Q99.102","Z48.000x002","B90.001","Z02.800","Z51.800","T92.603","T92.602","T92.300x017","R61.901","T93.300x003","Z52.000","Z73.900","Z04.300","R79.000x001","T92.500x014","R11.x02","Z54.800x003","Z30.800x004","Z54.000x015","Z76.100","T92.400x005","R19.002","Z09.900x001","Z54.000x002","M24.805","Z23.800x001","T80.203","Z03.800x711","Z43.603","T91.800x004","B90.802","R60.901","Z30.000x001","Z72.300","R76.000x001","R77.900","Z63.500x003","T93.400x006","M24.806","R76.802","T93.500x001","Z54.000x016","Z13.700","Z57.000","Z57.600","Z61.300x001","Z22.101","Z27.300","Z56.200","Z11.800x001","R77.200x001","T91.001","R63.500","T92.100x008","Z00.300","Z47.800x004","R41.300x001","Z22.303","Z58.100","R10.200x001","R69.x00","M23.202","R52.200","Z23.500","T90.401","T87.200","Z28.900","R53.x00x009","Z57.900","R76.100x001","Z03.800x701","Z22.200","R11.x01","Z45.804","Z47.800x009","T98.000","Z00.200","T93.800x002","R74.800x006","T92.500x003","Q91.000","T90.400x002","Z32.000x001","Q99.000","T92.001","B90.002","Q92.500","R58.x00x005","R82.100","T95.800x007","R47.000x001","T95.100x002","B90.101","T94.002","Q97.900","I69.800x002","Q98.200","Q92.100","Z09.300","T90.204","R74.900x001","R89.900x002","T92.301","R74.800x005","Z03.300","Z20.801","T92.303","Z12.901","R79.800x005","Q98.900","Z50.700x001","Z54.000x014","Z47.800x019","Z70.200","T92.300x013","T92.202","T92.302","R93.800x003","R74.800x003","R19.000x008","R44.801","Z04.002","Q99.200","Z20.802","T93.208","T95.000x008","Z54.800x001","R77.801","Z11.200","T91.500x003","Q92.600","T93.600x001","Z31.500","T90.400x004","T92.400","Z31.402","Z01.502","Z27.000","Z43.402","Z45.101","Z61.800","Q98.100","T75.200","Z30.900","T92.200","Z43.604","Z57.506","Z45.806","Z01.800x002","M23.212","T92.500x011","Z60.400","Z61.500x001","B90.200x002","T92.203","Z43.100","T92.100x009","T91.000x004","T90.200x012","B90.901","Z76.800x001","Z54.000x010","Z50.300","Z59.400","Z27.100","R25.200x005","Z01.503","T93.600x003","Z57.800","Z31.400x003","M23.201","R60.100","T95.800x001","Z63.900","Z59.300","Z74.800","R47.001","Z29.800","Z54.000x021","R18.x00x001","R19.003","T92.501","R18.x01","T92.307","R18.x00x005","R68.101","T95.800x003","T90.207","Z11.600","T92.601","B90.201","Z11.400","T92.500x010","Z30.302","T92.400x002","Z62.100x001","Z75.900x001","T92.300x015","R62.000x002","Z46.700","Z47.800x020","T93.500x002","Z63.800x001","Z61.600x001","T93.200x013","T92.101","Z41.900","T95.400","R46.800x001","R53.x00x003","R76.900","R49.800x003","Q87.806","Z60.500","Q91.100","Z62.600x001","R19.000x013","Z13.800x032","Z24.400","Q93.800","Z54.000x020","Z75.400","R77.000","T93.100","Z22.402","Z55.900","R25.200x007","Z09.802","I69.802","T91.800x003","T91.202","T90.500x002","Z58.300","Z30.800x005","Z31.600x001","T92.100","R63.100","Z56.500","R74.800x008","Z43.801","T93.800","R11.x03","T92.502","R47.000x008","R74.001","Z43.602","Q93.000","Z02.600","Z46.701","R19.004","T92.500x012","R76.100","R79.000","Z63.400x001","T92.102","R68.300","Z54.700","Z58.500","Z60.200x001","Z73.000","R23.100","T98.300x007","Z41.801","R79.805","T84.700","Z20.000","Z64.400x002","Z10.300","R85.901","R79.800x003","Z23.100","Z47.800x024","Z01.800x004","B94.000","R61.900","R53.x00x011","Z24.001","Z30.800x002","T95.000x011","T91.800x008","Z22.103","Z63.700x021","T90.800x002","Z11.100","R77.101","R89.300","Z47.800x029","Z50.101","R46.100","R47.002","T95.800x006","T93.205","Z52.001","Q96.800","M23.215","R99.x01","T91.200x002","Z56.000","Z59.600","T92.801","Z03.103","Z30.501","T92.300x006","T92.100x005","Z02.300","R61.000","T92.600x003","T93.200x007","Z22.401","Q97.000","Z13.801","Z04.500","Q90.100","R64.x00x002","T93.000","Z54.000x019","Z62.500x001","T91.400","Z27.200","Z45.201","Z03.900x001","Z65.300x005","Z59.100","Z20.600","Z30.301","T95.100x003","T97.x02","Q95.100","Z13.001","B90.903","R89.700","T93.207","T95.102","Z03.802","Z20.500","Z04.601","Z44.300","T95.000x004","Z47.800x018","R89.200","Z00.600","R82.500x001","Z01.002","T70.900","T95.200x006","Z12.000","T81.601","Z02.400","T93.900","R89.900x001","Z71.900","T93.800x003","T92.304","Z00.001","T91.800x006","B94.801","Z73.200","Z11.500","Z00.500x001","Z12.200","R79.900","Z31.202","Z75.300","M23.208","Z54.800x007","Z65.400x001","R46.300","R79.000x004","Z00.401","R61.100","M23.211","Q96.000","R41.100","Z01.600x002","Z28.800","Z63.700x001","Z65.500x002","Z54.000x017","T95.001","Z23.000","Z47.800x006","Z73.400","Z47.800x011","T96.x00x002","Z72.200","Z03.800","T93.501","Z58.200","Z63.800x004","Z58.700","Z43.301","Z55.300","Z61.100x001","Z03.100","Z63.800x003","Z01.200","Z76.300","Q97.800","Z43.201","R93.202","Q96.900","T95.301","Z47.800x035","Z47.800x027","R53.x00x005","R77.100","Z50.501","Z47.800x016","Z71.500","R72.x00x002","R85.902","T92.100x011","T92.300x001","Z47.800x026","Z65.100x001","R68.300x002","Z30.103","Z51.300","Z54.800x005","Z43.200","T93.203","T91.000x001","Q92.700","T85.806","B90.200x003","R89.900x003","Z28.101","R46.600","Z56.600","Z54.000x006","R19.000x009","T80.800","T92.300x012","T97.x00x003","T95.803","T84.901","Z31.400x004","Z43.401","R19.001","R68.200","Z59.900","T92.300","T93.300x008","T96.x00x003","Z04.200","R98.x00x002","Z12.600","K07.601","Z22.800","Z23.700","R71.x00x004","T93.202","R46.000","Z45.805","Z47.800x013","Z63.700x091","R71.x00x005","Z73.300","Q95.900","R41.000","Z47.800x015","Z50.200","T93.104","Q99.100","Z57.502","R62.802","R77.800x006","T95.000x001","Z57.505","T92.401","Z12.500","Z72.600","Z54.000x013","Q92.900","R52.901","T90.206","Z30.400x004","Z57.501","Q92.000","T92.504","T93.200x012","Z51.400x001","B94.802","T95.201","Z45.200","Z23.600","B94.100","T91.000x002","T93.001","T82.812","Z09.400","T90.200","Z31.203","Z54.000x005","R53.x00x010","T93.301","Z46.500x001","Z54.300","Z43.400x003","R77.802","T85.902","R53.x00x008","T92.500x013","Z51.600","R62.801","T93.200","Z54.000x003","Z60.000x001","R25.200x002","T90.202","Z50.000","T92.500x007","B94.800x003","Z42.900","Z13.300x002","Z62.400x001","Z72.900","R47.100x002","R60.000","T91.401","Z74.300","T98.301","Z51.400x003","T84.400","R62.000x003","R84.901","Z03.900","Z20.400","Z22.000","R46.801","M23.214","Z54.000x004","Z71.000","Z75.100","Q99.800","Z24.500","E89.900","Z01.102","R53.x00x002","R74.801","Z12.900x001","Z10.000","T94.100","Z47.800x003","Z22.801","R93.501","Z72.800","Z03.800x721","T91.200x005","Z12.400","Q97.200","T92.000","Z23.400","Z11.300","Z71.700","Z47.800x022","Q99.801","Z50.800x002","T95.800x005","T92.201","T73.800","Z01.900","Z13.800x041","Z01.800x001","Z76.900","T92.800x002","Z56.300","R53.x00x012","Z76.400","Z43.700","Z71.200","T69.900","T91.500x001","Z24.100","Z45.807","T90.201","T92.400x003","T93.400x004","T94.102","T91.502","T92.600x002","Z11.901","Z22.400","Q98.000","Z71.300","R87.900x002","Z61.000x001","R54.x01","Z74.100x001","T93.300x001","T98.200x031","T93.102","R77.800x003","T93.200x010","R63.200","Z50.801","T92.400x008","Z30.400x003","Q91.600","Q95.200","Z64.400x003","R79.803","Z74.200","R68.100x001","Z47.800x025","T95.000x007","Z61.400x001","T95.000x003","R89.600","Z13.800x031","Z63.700x092","R23.100x002","T91.800x007","Z50.900x001","Z65.400x003","T93.200x002","Z01.501","B94.101","Z59.800","R61.001","Z43.900x001","T92.204","Q98.700","Z47.800x023","Z76.000","R62.803","R74.803","Z65.300x003","Q98.400","Z74.000","Z72.100","Q89.901","Z02.100","T91.501","T92.400x004","Z27.800","Z31.401","Z40.900x001","T95.202","B90.902","Z72.000","R63.000","T88.901","Z54.000x007","R89.800","T85.802","R76.801","Z20.200","Z10.100","T91.800x002","Z29.000","Z39.100x003","T73.200","T95.000x005","Z29.900","Z44.200x002","Z61.900x001","Z13.100","Z13.800x022","M24.810","Z74.900","T98.200","Z01.001","Z26.900","R46.500","R63.300x003","T93.101","T95.200x002","Z42.000","B90.904","Z30.000x002","T90.400x003","Z25.000","Z54.000x008","Z64.300","Z02.900","Z60.300x002","R62.900","Z46.900","Z10.200","Z57.300","R87.900x001","Z57.400","Z63.800x002","Z26.800","B94.200","Z04.001","T95.002","T95.300x002","T95.900","Z13.600","Z65.900","T95.200x004","Z47.800x010","Z43.600x002","Z47.800x017","Z11.801","Z47.800x034","T92.800x001","T92.402","Q98.500","R26.100","Z30.202","R47.000x005","Z58.900","Z61.700x001","R87.900x003","Z30.505","Z58.600","B94.900","T94.000","Q87.801"};
        String[] dept_list={};
        if (!(true && Base.contains(mdc_zd,record.zdList[0]))){
            return "";
        }
        
        Base.groupMessages.putMessage(record.Index,"符合MDCX入组条件，匹配规则：主诊断匹配");
        String result;

        result=XJ1.group(record);
        if (result.length()>0){
            return result;
        }

        if (false && record.ssList!=null && record.ssList.length>0 && Base.contains(Base.SS_VALID,record.ssList[0])){
            Base.groupMessages.putMessage(record.Index,"符合XQY入组条件，存在有效手术操作："+String.join(",",Base.Intersect(record.ssList,Base.SS_VALID)));
            return "XQY";
        }

        result=XR1.group(record);
        if (result.length()>0){
            return result;
        }

        result=XR2.group(record);
        if (result.length()>0){
            return result;
        }

        result=XR3.group(record);
        if (result.length()>0){
            return result;
        }

        result=XS1.group(record);
        if (result.length()>0){
            return result;
        }

        result=XS2.group(record);
        if (result.length()>0){
            return result;
        }

        result=XT1.group(record);
        if (result.length()>0){
            return result;
        }

        result=XT2.group(record);
        if (result.length()>0){
            return result;
        }

        result=XT3.group(record);
        if (result.length()>0){
            return result;
        }

        Base.groupMessages.putMessage(record.Index,"不符合MDCX的ADRG入组条件");
        return "";
    }
}

